home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
CU Amiga Super CD-ROM 18
/
CU Amiga Magazine's Super CD-ROM 18 (1997)(EMAP Images)(GB)[!][issue 1998-01].iso
/
CUCD
/
Programming
/
AmigaE
/
Src
/
Gfx
/
IntMandel.e
< prev
next >
Wrap
Text File
|
1992-09-02
|
1KB
|
57 lines
-> Yet Another Mandel, translated from Oberon. integer this time.
OPT OSVERSION=37, REG=5
MODULE 'tools/clonescreen'
CONST DEPTH=4,COLOURS=16 -> related :-)
CONST ITERDEPTH=25
PROC main() HANDLE
DEF zr,zi,ar,ai,dr,di,sr,si,st,x,y,i,
screen=NIL,font=NIL,win=NIL,xsize,ysize,depth
screen,font:=openclonescreen('Workbench','YAM',DEPTH)
win:=backdropwindow(screen)
depth,xsize,ysize:=getcloneinfo(screen)
x:=256/COLOURS*2
FOR i:=0 TO COLOURS-1 DO SetColour(screen,i,0,i*x,i*x)
sr:=$400000/xsize -> shrink horiz
si:=$300000/ysize -> shrink vert
st:=$140000*-2 -> move side
zi:=$160000 -> move up
FOR y:=ysize-1 TO 0 STEP -1
IF CtrlC() THEN Raise("^C")
zi:=zi-si
zr:=st
FOR x:=0 TO xsize-1
i:=0; ar:=zr; ai:=zi
REPEAT
dr:=Shr(ar,10); di:=Shr(ai,10)
ai:=dr*2*di+zi
dr:=dr*dr; di:=di*di
ar:=dr-di+zr
i++
UNTIL (i>ITERDEPTH) OR (dr+di>$400000)
Plot(x,y,Mod(i,COLOURS))
zr:=zr+sr
ENDFOR
ENDFOR
EasyRequestArgs(NIL,[20,0,'Wake Up!','I''m finished!','Ok!'],0,NIL)
EXCEPT DO
closeclonescreen(screen,font,win)
SELECT exception
CASE "SCR"; WriteF('no screen!\n')
CASE "WIN"; WriteF('no window!\n')
ENDSELECT
ENDPROC